1507. История Лорела - Харди

 

Пила по дереву имеет вид сегмента AFB окружности радиуса r. Харди садится на конец B, а Лорел – на конец A (Харди тяжелее Лорела). Известно расстояние d = FE между серединой отрезка AB и серединой дуги AFB. Расстояние от точки B до земли равно h1. Найти h2 – расстояние от точки A до земли.

 

\epsfbox{p10792b.eps}

 

Вход. Первая строка содержит количество тестов n (0 < n £ 1000). Каждый тест содержит три числа r, d и h1 (10 £ r £ 100, 5 £ d £ r, 5 £ h1 £  d).

 

Выход. Для каждого теста вывести в отдельной строке его номер и величину h2, округленную до четырех десятичных знаков.

 

Пример входа

Пример выхода

2
10 10 10
10 7 6
Case 1: 10.0000
Case 2: 8.0342

 

 

РЕШЕНИЕ

геометрия

 

Анализ алгоритма

В треугольнике OEB: OB = r, OE = rd, sin ÐEBO = (rd) / r.

В треугольнике OKB: OB = r, OK = rh1, sin ÐKBO = (rh1) / r.

Находим ÐKBA = ÐKBO – ÐEBO.

Из треугольника OEB: EB = , AB = 2 * EB.

Из треугольника BDX: BX = BD / sin ÐDXB = h1 / sin  ÐKBA.

Находим AX = AB + BX.

Из треугольника ACX находим ответ: h2 = AC = AX * sin ÐDXB.

 

Реализация алгоритма

Читаем количество тестов t.

 

scanf("%d",&t);

for(i = 0; i < t; i++)

{

 

Читаем входные данные текущего теста.

 

  scanf("%lf %lf %lf",&r,&d, &h1);

  printf("Case %d: ",i+1);

 

Вычисляем b = ÐKBA = ÐKBO – ÐEBO = arcsin(rh1) / r – arcsin(rd) / r.

 

  b = asin((r - h1)/r) - asin((r-d)/r);

 

Если b = 0, то точки A и B находятся на одинаковом расстоянии от земли (прямой CX) и h2 = h1.

 

  if (b == 0.0)

  {

    printf("%0.4lf\n",h1);

    continue;

  }

 

Вычисляем AX = 2 *  + h1 / sin ÐKBA.

 

  ax = 2 * sqrtl(r*r - (d-r)*(d-r)) + h1/sin(b);

 

Находим ответ h2 = AX * sin ÐDXB (ÐDXB = ÐKBA) и выводим его.

 

  h2 = ax * sin(b);

  printf("%0.4lf\n",h2);

}